///******************************************************************************* // * Copyright (c) 2000, 2006 IBM Corporation and others. // * All rights reserved. This program and the accompanying materials // * are made available under the terms of the Eclipse Public License v1.0 // * which accompanies this distribution, and is available at // * http://www.eclipse.org/legal/epl-v10.html // * // * Contributors: // * IBM Corporation - initial API and implementation // *******************************************************************************/ // //package org.eclipse.ui.tests.keys; // //import java.io.FileNotFoundException; //import java.io.IOException; //import java.util.ArrayList; //import java.util.List; // //import org.eclipse.core.commands.common.CommandException; //import org.eclipse.core.runtime.CoreException; //import org.eclipse.jface.bindings.keys.KeyStroke; //import org.eclipse.jface.bindings.keys.ParseException; //import org.eclipse.swt.widgets.Event; //import org.eclipse.swt.widgets.MenuItem; //import org.eclipse.swt.widgets.Shell; //import org.eclipse.ui.IWorkbenchWindow; //import org.eclipse.ui.internal.Workbench; //import org.eclipse.ui.internal.keys.BindingService; //import org.eclipse.ui.keys.IBindingService; //import org.eclipse.ui.tests.harness.util.UITestCase; // ///** // * Tests Bug 40023 // * // * @since 3.0 // */ //public class Bug40023Test extends UITestCase { // // /** // * Retrieves a menu item matching or starting with the given name from an // * array of menu items. // * // * @param menuItems // * The array of menu items to search; must not be <code>null</code> // * @param text // * The text to look for; may be <code>null</code>. // * @return The menu item, if any is found; <code>null</code> otherwise. // */ // public static MenuItem getMenuItem(MenuItem[] menuItems, String text) { // for (int i = 0; i < menuItems.length; i++) { // if (menuItems[i].getText().startsWith(text)) { // return menuItems[i]; // } // } // // return null; // } // // /** // * Constructor for Bug40023Test. // * // * @param name // * The name of the test // */ // public Bug40023Test(String name) { // super(name); // } // // /** // * Tests that check box items on the menu are checked when activated from // * the keyboard. // * // * @throws CommandException // * If execution of the handler fails. // * @throws CoreException // * If the exported preferences file is invalid for some reason. // * @throws FileNotFoundException // * If the temporary file is removed before it can be read in. // * (Wow) // * @throws IOException // * If the creation of or the writing to the temporary file // * fails for some reason. // * @throws ParseException // * If the key binding cannot be parsed. // */ // public void testCheckOnCheckbox() throws CoreException, CommandException, // FileNotFoundException, IOException, ParseException { // // Open a window to run the test. // IWorkbenchWindow window = openTestWindow(); // Workbench workbench = (Workbench) window.getWorkbench(); // // // Set up a key binding for "Lock Toolbars". // String commandId = "org.eclipse.ui.window.lockToolBar"; //$NON-NLS-1$ // String keySequenceText = "CTRL+ALT+L"; //$NON-NLS-1$ // PreferenceMutator.setKeyBinding(commandId, keySequenceText); // // // Press "CTRL+ALT+L" to lock the toolbars. // List keyStrokes = new ArrayList(); // keyStrokes.add(KeyStroke.getInstance(keySequenceText)); // Event event = new Event(); // BindingService support = (BindingService) workbench // .getAdapter(IBindingService.class); // support.getKeyboard().press(keyStrokes, event); // // // Check that the "Lock Toolbars" menu item is now checked. // Shell shell = window.getShell(); // MenuItem windowMenu = getMenuItem(shell.getMenuBar().getItems(), // "&Window"); //$NON-NLS-1$ // MenuItem lockToolBarsMenuItem = getMenuItem(windowMenu.getMenu() // .getItems(), "Lock the &Toolbars"); //$NON-NLS-1$ // assertTrue("Checkbox menu item is not checked.", lockToolBarsMenuItem //$NON-NLS-1$ // .getSelection()); // } //}